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(g) Asynchronous remote data duplexing. 

(g) A remote data shadowing system provides 
storage based, real time disaster recovery 
capability. Record updates at a primary site 
cause write I/O operations in a storage subsys- 
tem th«*ein. The write I/O operations are time 
stamped and the time, sequence, and physical 
locations of the record updates are collected in 
a primary data mover. The primary data mover 
groups sets of the record updates and as- 
sociated control information based upon a pre- 
determined time interval, the primary data 
mover appending a prefix header to the record 
updates thereby forming self describing record 
sets. The self describing record sets are trans- 
mitted to a remote secondary site wherein con- 
sistency groups are fomned such that the record 
updates are ordered so that the record updates 
can be shadowed in an order consistent with 
the order the record updates cause write I/O 
operations at the primary site. 
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The present invention relates generally to disas- 
ter recovery techniques in data processing systems, 
and more particularly, to a system for real-time re- 
mote copying of data. 

Data processing systems, in conjunction with 
processing data, typically are required to store large 
amounts of data (or records), which data can be effi- 
ciently accessed, modified, and re-stored. Data stor- 
age is typically separated into several different levels, 
or hierarchically, in order to provide efficient and cost 
effective data storage. A first, or highest level of data 
storage involves electronic memory, usually dynamic 
or static random access memory (DRAM or SRAM). 
Electronic memories take the form of semiconductor 
integrated circuits wherein millions of bytes of data 
can be stored on each circuit, with access to such 
bytes of data measured in nano-seconds. The elec^ 
tronic memory provides the fastest access to data 
since access is entirely electronic. 

A second level of data storage usually involves di- 
rect access storage devices (DASD). DASD storage, 
for example, can comprise magnetic and/or optical 
disks, which store bits of data as micrometer sized 
magnetic or optical altered spots on a disk surface for 
representing the "ones" and "zeros' that make up 
those bits of the data. Magnetic DASD, includes one 
or more disks that are coated with remnant magnetic 
material. The disks are rotatably mounted within a 
protected environment. Each disk is divided Into many 
concentric tracks, or closely spaced circles. The data 
is stored serially, bit by bit, along each track. An ac- 
cess mechanism, known as a head disk assembly 
(HDA), typically includes one or more read/write 
heads, and is provided in each DASD for moving 
across the tracks to transfer the data to and from the 
surface of the disks as the disks are rotated past the 
read/write heads. DASDs can store giga-bytes of data 
with the access to such data typically measured in 
milli-seconds (orders of magnitudes slower than elec- 
tronic memory). Access to data stored on DASD is 
slower due to the need to physically position the disk 
and HDA to the desired data storage location. 

A third or lower level of datastorage includes tape 
and/or tape and DASD libraries. At this storage level, 
access to data is much slower in a library since a robot 
is necessary to select and load the needed data stor- 
age medium. The advantage is reduced cost for very 
large data storage capabilities, for example, tera- 
bytes of data storage. Tape storage is often used for 
back-up purposes, that is, data stored at the second 
level of the hierarchy is reproduced, for safe keeping 
on magnetic tape. Access to data stored on tape 
and/or in a library is presently of the order of seconds. 

Having a back-up data copy is mandatory for 
many businesses as data loss could be catastrophic 
to the business. The time required to recover data lost 
at the primary storage level is also an important re- 
covery consideration. An improvement in speed over 



tape or library back-up, includes dual copy. An exam- 
ple of dual copy invoh^es providing additional DASD's 
so that data is written to the additional DASDs (some- 
times referred to as mirroring). Then if the primary 
5 DASDs fall, the secondary DASDs can be depended 
upon for data. A drawback to this approach is that the 
number of required DASDs is doubled. 

Another data back-up alternative that overcomes 
the need to provide double the storage devices in- 
to volves writing data to a redundant array of inexpen- 
sive devices (RAID) configuration. In this instance, 
the data is written such that the data is apportioned 
amongst many DASDs. If a single DASD fails, then 
the lost data can be recovered by using the remaining 
IS data and error correction procedures. Currently there 
are several different RAID configurations available. 

The aforementioned back-up solutions are gen- 
erally sufficient to recover data in the event that a 
storage device or medium fails. These back-up meth- 
20 ods are useful only for device failures since the sec- 
ondary data is a mirror of the primary data, that Is, the 
secondary data has the same volume serial numbers 
(VOLSERs) and DASD addresses as the primary 
data. System failure recovery, on the other hand, is 
25 not available using mirrored secondary data. Hence 
still further protection is required for recovering data 
if a disaster occurs destroying the entire system or 
even the site, for example, earthquakes, fires, explo- 
sions, hurricanes, etc. Disaster recovery requires that 
30 the secondary copy of data be stored at a location re- 
mote from the primary data. A known method of pro- 
viding disaster protection is to back-up data to tape, 
on a daily or weekly basis, etc. The tape is then picked 
up by a vehicle and taken to a secure storage area 
35 usually some kilometers away from the primary data 
location. A problem is presented in this back-up plan 
in that It could take days to retrieve the back-up data, 
and meanwhile several hours or even days of data 
could be lost, or worst, the storage location could be 
40 destroyed by the same disaster. A somewhat im- 
proved back-up method would be to transmit data to 
a back-up location each night. This allows the data to 
be stored at a more remote location. Again, some data 
may be lost between back-ups since back-up does 
45 not occur continuously, as in the dual copy solution. 
Hence, a substantial data amount could t>e lost which 
may be unacceptable to some users. 

More recently introduced data disaster recovery 
solutions include remote dual copy wherein data is 
50 backed-up not only remotely, but also continuously. In 
order to communicate duplexed data. from one host 
processor to another host processor, or from one stor- 
age controller to another storage controller, or some 
combination thereof, a substantial amount of control 
55 data is required for realizing the process. A high over- 
head, however, can interfere with a secondary site's 
ability to keep up with a primary site's processing, 
thus threatening the ability of the secondary site to be 
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able to recover the primary in the event a disaster oc- 
curs. 

Accordingly it is desired to provide a method and 
apparatus for providing a real time update of data 
consistent with the data at a primary processing loca- 
tion using minimal control data, wherein the method 
and apparatus operates independently of a particular 
application data being recovered, that is, generic stor- 
age media based rather than specific application data 
based. 

An aim of the present invention is to provide an 
improved system and method for shadowing DASD 
data to a secondary site for disaster recovery. 

According to a first aspect of the present inven- 
tion, a method for forming consistency groups pro- 
vides for disaster recovery capability from a remote 
site. Data updates generated by one or more applica- 
tions running in a primary processor are received by 
a primary storage subsystem, wherein the primary 
storage subsystem causes I/O write operations to 
write each data update therein. The primary storage 
subsystem is synchronized by a common timer, and 
a secondary system, remote from the primary proc- 
essor, shadows the data updates in sequence consis- 
tent order such that the secondary site is available for 
disaster recovery purposes. Thee method comprising 
steps of: (a) time stamping each write I/O operation 
occurring in the primary storage subsystem; (b) cap- 
turing write I/O operation record set information from 
the primary storage subsystem for each data update; 
(c) generating self describing record sets from the 
data updates and the respective record set informa- 
tion, such that the self describing record sets are suf- 
ficient to re-create a sequence of the write I/O oper- 
attons; (d) grouping the self describing record sets 
into interval groups based upon a predetermined in- 
terval threshold; and (e) selecting a first consistency 
group as that interval group of self describing record 
sets having an earliestoperational time stamp, the in- 
dividual data updates being ordered within the first 
consistency group based upon time sequences of the 
I/O write operations in the primary storage subsys- 
tem. 

In another aspect of the present invention, a pri- 
mary system has a primary processor running one or 
more applications, wherein the applidations generat- 
ing record updates, and the primary processor gen- 
erating self describing record sets therefrom. Each 
self describing record set is sent to a secondary sys- 
tem remote from the primary system, wherein the 
secondary system shadows the record updates in se- 
quence consistent order based upon the self describ- 
ing record sets for real time disaster recovery purpos- 
es. The primary processor is coupled to a primary 
storage subsystem wherein the primary storage sut>- 
system receives the record updates and causes I/O 
write operations for storing each record update there- 
in. The primary processor comprises a sysplex timer 



for providing a common time source to the applica- 
tions and to the primary storage subsystem for syn- 
chronization purposes, and a primary data mover, 
synchronized by the sysplex timer, prompts the pri- 

5 mary storage subsystem for providing record set in- 
formation to the primary data mover for each record 
update. The primary data mover groups a plurality of 
record updates and each corresponding record set in- 
formation into time interval groups, and inserts a pre- 

10 fix header thereto. Each time interval group forms the 
self describing record sets. 

A preferred embodiment of the invention will now 
be described, by way of example only, with reference 
to the accompanying drawings in which: 

IS FIG. 1 is a block diagram of a disaster recovery 

system having synchronous remote data shadowing 
capabilities. 

FIG. 2 is a flow diagram of a method for providing 
synchranous remote copy according to the disaster 
20 recovery system of FIG. 1 . 

FIG. 3 is a flow diagram of a method of an I/O er- 
ror recovery program (I/O ERP) operation. 

FIG. 4 is a block diagram of a disaster recovery 
system having asynchronous remote data shadowing 
25 capabilities. 

FIG. 5 is a data format diagram showing a prefix 
header that prefixes read record sets from the pri- 
mary site of FIG. 4. 

FIG. 6 is a data fonmat diagram describing fields 
30 making up a read record set 

FIG. 7 is a state table Identifying volume config- 
uration information. 

FIG. 8 is a master journal as used by the second- 
ary site of FIG. 4. 
35 FIG. 9 is an example sequence for forming a con- 

sistency group. 

FIG. 10 is a flow diagram showing a method of 
collecting information and read record sets for form- 
ing consistency groups. 
40 FIG. 11 is a flow diagram showing a method of 

forming consistency groups. 

FIG. 1 2 is a table indicating full consistency group 
recovery rules application for an ECKD architecture 
device for a given sequence of I/O operations to a 
45 DASD track- 

FIG. 1 3 is a description of the rules to be used in 
the table of FIG. 12. 

FIG. 14 is a flow diagram of a method of writing 
read record set copies to a secondary site with full 
50 consistency group recovery capability. 

A typical data, pcocessing. system may take the 
form of a host processor, such as an IBM System/360 
or IBM System/370 processor for computing and ma- 
nipulating data, and running, for example, data facility 
55 storage management subsystem/multiple virtual sys- 
tems (DFSMS/MVS) software, having at least one 
IBM 3990 storage controller attached thereto, the 
storage controller comprising a memory controller 
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and one or nrare cache memory types incorporated 
therein. The storage controller Is further connected to 
a group of direct access storage devices (DASDs) 
such as IBM 3380 or 3390 DASDs. While the host 
processor provides substantial computing power, the 
storage controller provides the necessary functions 
to efficiently transfer, stage/destage. convert and 
generally access large databases. 

Disaster recovery protection for the typical data 
processing system requires that primary data stored 
on primary DASDs be backed-up at a secondary or 
remote location. The distance separating the primary 
and secondary locations depends upon the level of 
risk acceptable to the user, and can vary from several 
kilometers to thousands of kilometers. The second- 
ary or remote location, in addition to providing a back- 
up data copy, must also have enough system informa- 
tion to take over processing for the primary system 
should the primary system become disabled. This is 
due in part because a single storage controller does 
not write data to both primary and secondary DASD 
strings at the primary and secondary sites. Instead, 
the primary data is stored on a primary DASD string 
attached to a primary storage controller while the 
secondary data is stored on a secondary DASD string 
attached to a secondary storage controller. 

The secondary site must not only be sufficiently 
remote from the primary site, but must also be able 
to back-up primary data in real time. The secondary 
site needs to back-up primary data as the primary 
data is updated with some minimal delay. Additional- 
ly, the secondary site has to back-up the primary data 
regardless of the application program (e.g., IMS, 
DB2) running at the primary site and generating the 
data and/or updates. A diff icult task required of the 
secondary site is that the secondary data must be or- 
der consistent, that is, secondary data is copied in the 
same sequential order as the primary data (sequen- 
tial consistency) which requires substantial systems 
consideratbns. Sequential consistency is complicat- 
ed by the existence of multiple storage controllers 
each controlling multiple DASDs in a data processing 
system. Without sequential consistency, secondary 
data inconsistent with primary data would result, thus 
corrupting disaster recovery. 

Remote data duplexing falls into two general cat- 
egories, synchronous and asynchronous. Synchron- 
ous remote copy involves sending primary data to the 
secondary locatk>n and confirming the reception of 
such data before ending a primary DASD input/output 
(I/O) operation (providing a channel end.(CE)^and de- 
vice end (DE) to the primary host). Synchronous 
copy, therefore, slows the primary DASD I/O re- 
sponse time while waiting for secondary confirma- 
tion. Primary I/O response delay is increased propor- 
tionately with the distance between the primary and 
secondary systems - a fector that limits the remote 
distance to. tens of kilometers. Synchronous copy. 



however, provides sequentially consistent data at the 
secondary site with relatively little system overhead. 

Asynchronous remote copy provides better pri- 
mary application system performance because the 
5 primary DASD I/O operation is completed (providing 
a channel end (CE) and device end (DE) to the pri- 
mary host) b^ore data is confirmed at the secondary 
site. Therefore, the primary DASD I/O response time 
is not dependent upon the distance to the secondary 
10 site and the seoondary site could be thousands of 
kilometers remote from the primary site. A greater 
amount of system overhead is required, however, for 
ensuring data sequence consistency since data re- 
ceived at the secondary site will often not be in order 
15 of the primary updates. A failure at the primary site 
could result in some data being lost that was in transit 
between the primary and secondary locations. 

Synchronous real time remote copy for disaster 
recovery requires that copied DASD volumes form a 
20 set Forming such a set further requires that a suffi- 
cient amount of system information be provided to the 
secondary site for identifying those volumes (VOLS- 
ERs) comprising each set and the primary site equh/- 
alents. Importantly, the secondary site forms a "du- 
25 plex pair" with the primary site and the secondary site 
must recognize when one or more volumes are out of 
sync with the set that is, "failed duplex" has occurred. 
Connect failures are nK>re visible in synchronous re- 
mote copy than in asynchronous remote copy be- 
30 cause the primary DASD I/O is delayed while alter- 
nate paths are retried. The prirr^y site can abort or 
suspend copy to allow the primary site to continue 
while updates for the secondary site are queued, the 
primary site marking such updates to show the sec- 
35 ondary site is out of sync. Recognizing exception con- 
ditions that may cause the secondary site to fall out 
of sync with the primary site is needed in order that 
the secondary site be available at any time for disas- 
ter recovery. Error conditions and recovery actions 
40 must not make the secondary site inconsistent with 
the primary site. 

Maintaining a connection between the secondary 
site and the primary site with secondary DASD pres- 
ent and accessible, however, does not ensure content 
45 synchronism. The secondary site may lose synchron- 
ism with the primary site for a number of reasons. The 
secondary site is initially out of sync when the duplex 
pair is being formed and reaches sync when an initial 
data copy is completed. The primary site may break 
50 the duplex pair if the primary site is unable to write up- 
dated data to the secondary site in which case the. pdr 
mary site writes updates to the primary DASD under 
suspended duplex pair conditions so that the updat- 
ing application can continue. The primary site is thus 
55 running exposed, that is, without current disaster pro- 
tection copy until the duplex pair is restored. Upon re- 
storing the duplex pair, the secondary site is not im- 
mediately in sync. After applying now pending up>- 
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dates, the secondary site returns to sync. The pri- 
mary site can also cause the secondary site to lose 
sync by issuing a suspend command for that volume 
to the primary DASD. The secondary site re-syncs 
with the primary site after the suspend command is 
ended, duplex pair is re*established, and pending up- 
dates are copied. On*line maintenance can also 
cause synchronization to be lost. 

When a secondary volume is out of sync with a 
primary volume, the secondary volume is not useable 
for secondary system recovery and resumption of pri- 
mary applications. An out-of-sync volume at the sec- 
ondary site must be identified as such and secondary 
site recovery-takeover procedures need to identify 
the out-of-sync volumes for denying application ac- 
cess (forcing the volumes off-line or changing their 
VOLSERs). The secondary site may be called upon 
to recover the primary site at any instant wherein the 
primary site host is inaccessible - thus the secondary 
site requires all pertinent information about a sync 
state of all volumes. The secondary storage subsys- 
tem, that is the secondary storage controllers and 
DASD, is unable to determine all conditions causing 
the primary site to break synchronism due to primary 
site-encountered exceptions. For example, the pri- 
mary site may break a duplex pair if the primary site 
is unable to access the secondary peer due to a pri- 
mary I/O path or link failure that the secondary site is 
unaware of. In this case the secondary site shows in- 
sync state while the primary site indicates the duplex 
pair is broken. 

External communication may notify the second- 
ary site that an out-of-sync duplex pair volume exists. 
This is realizable by employing a user systems man- 
agement function. Primary I/O operations end with 
channel end/device end/unit check (CE/DE/UC) sta- 
tus and sense data indicates the nature of the error. 
With this form of I/O configuration an error recovery 
pnDgram (ERP) processes the error and send an ap- 
propriate message to the secondary processor before 
posting the primary application that I/O is complete. 
The user is then responsible to recognize the ERP 
suspend duplex pair message and secure that infor- 
mation at the secondary location. When the second- 
ary Site is depended upon to become operational In 
place of the primary site, a start-up procedure brings 
the secondary DASD on-line to the secondary host 
wherein sync status stored in the secondary DASD 
subsystem is retrieved for ensuring that out-of-sync 
volumes are not brought on-line for application alloca- 
tion. This sync status merged.with..all ERP suspend 
duplex pair messages gives a complete picture of the 
secondary out-of-sync volumes. 

Referring now to FIG. 1, a disaster recovery sys- 
tem 10 is shown having a primary site 14 and a sec- 
ondary site 15, wherein the secondary site 15 is lo- 
cated, for example, 20 kilo-meters remote from the 
primary site 14. The primary site 14 includes a host 
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processor or primary processor 1 having an applica- 
tion and system I/O and Error Recovery Program 2 
running therein (hereinafter referred to as I/O ERP 2). 
The primary processor 1 could be, for example, an 
5 IBM Enterprise Systems/9000 (ES/9000) processor 
running DFSMS/MVS operating software and further 
may have several application progranns running 
thereon. A primary storage controller 3, for example, 
an IBM 3990 Model 6 storage controller, is connected 
10 to the primary processor 1 via a channel 12. As is 
known in the art, several such primary storage con- 
trollers 3 can be connected to the primary processor 
1, or alternately, several primary processors 1 can be 
attached to the primary storage controllers 3. A pri- 
15 mary DASD 4, for example, an IBM 3390 DASD, is 
connected to the primary storage controller 3. Sever- 
. al primary DASDs 4 can be connected to the primary 
storage controller 3. The primary storage controller 3 
and attached primary DASD 4 form a primary sut>- 
20 storage system. Further, the primary storage control- 
ler 3 and the primary DASD 4 could be single integral 
units. 

The secondary site 15 includes a secondary 
processor 5. for example, an IBM ES/9000, connect- 

25 ed to a secondary storage controller 6, for example an 
IBM 3990 Model 3, via a channel 13. A DASD 7 is fur- 
ther connected to the secondary storage controller 6. 
The primary processor 1 is connected to the second- 
ary processor 5 by at least one host-to-host commu- 

30 nication link 11, for example, channel links or tele- 
phone T1/T3 line links, etc. The primary processor 1 
may also have direct connectivity with the secondary 
storage controller 6 by, for example, multiple Enter- 
prise Systems Connection (ESCON) links 9. As a re- 

35 suit, the I/O ERP 2 can communicate, if required, with 
the secondary storage controller 6. The primary stor- 
age controller 3 communicates with the secondary 
storage controller 6 via multiple peer-to-peer links 8, 
for example, multiple ESCON links. 

40 When a write I/O operation is executed by an ap- 

plication program running in the primary processor 1, 
a hardware status channel end/device end (CE/DE) is 
provided indicating the I/O operation completed suc- 
cessfully. Primary processor 1 operating system 
45 software marks the application write I/O successful 
upon successful completion of the I/O operation, thus 
permitting the application program to continue to a 
next write I/O operation which may be dependent 
upon the first or previous write I/O operation having 
50 successfully completed. On the other hand, if the 
write I/O operation was unsuccessful, the l/0..<status. 
of channel end/device end/unit check (hereinafter re- 
ferred to as CE/DE/UG) is presented to the primary 
processor 1 operating system software. Having pre- 
ss sented u nit check, the I/O ERP 2 takes control obtain- 
ing specific sense information from the primary stor- 
age controller 3 regarding the nature of the failed 
write I/O operation. If a unique error to a volume oc- 

5 
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curs then a unique status related to that error is pro- 
vided to the I/O ERP 2. The I/O ERP 2 can thereafter 
perform new peer-to-peer synchronization error re- 
covery for maintaining data integrity between the pri- 
mary storage controller 3 and the secondary storage 
controller 6, or in the worst case, between the primary 
processor 1 and the secondary processor 5. 

Referring to FIGs 2 and 3, the error recovery pro- 
cedure is set forth. In FIG. 2, a step 201 includes an 
application program running in the primary processor 
1 sending a data update to the primary storage con- 
troller 3. At step 203 the data update is written to the 
primary DASD 4, and the data update is shadowed to 
the secondary storage controller 6. At step 205 the 
duplex pair status is checked to determine whether 
the primary and secondary sites are synchronized. If 
the duplex pair status is in a synchronized state, then 
the data update is written to the secondary DASD 7 
at step 207 while processing then continues at the pri- 
mary processor 1 via application programs running 
thereat. 

In the case that the duplex pair is in a "failed" 
state, then at step 209 the primary storage controller 
3 notifies the primary processor 1 that duplex pair 
has suspended or failed. The duplex pair can become 
"failed" due to communication failure between the pri- 
mary storage controller 3 and the secondary storage 
controller 6 via communication links 8. Alternatively, 
duplex pair can become "failed" due to errors in either 
the primary or secondary subsystem. If the failure is 
in the communication links 8, then the primary stor- 
age controller 3 is unable to communicate the failure 
directly to the secondary storage controllers. At step 
211 the primary storage controller 3 returns I/O sta- 
tus CE/DE/UC to the primary processor 1. The I/O 
ERP 2 quiescesthe application programs hence tak- 
ing control of the primary processor 1 at step 213 for 
error recovery and data integrity before returning 
control to the application requesting the write I/O op- 
eration. 

FIG. 3 represents steps performed by the I/O 
ERP 2. The I/O ERP 2 issues a sense I/O to the pri- 
mary storage controller 3 at step 221. The sense I/O 
operation returns infonmation describing the cause of 
the I/O error, that is. the data description information 
is unique to the storage controllers or duplex pair op- 
eration regarding specific errors. In the event that the 
data description information indicates that the peer- 
to-peer communlcatton links 8 have failed between 
the primary storage controller 1 and the secondary 
storage controUer e,.then at step 223 the I/O ERP 2.. 
issues a storage controller level I/O operation against 
the primary storage controller 3 and the secondary 
storage controller 6 indicating that the affected vol- 
ume is to be placed in failed synchronous remote copy 
state. This secondary storage controller 6 is able to 
receh/e the state of the affected volume from the I/O 
ERP 2 via the - multiple ESCON links 9 or the host- 



to-host communication link 11. Consequently, the 
current status of the duplex pair operation is main- 
tained at tjoth the primary processor 1 and the sec- 
ondary processor 5 in conjunction with applications 
5 running in the primary processor 1 . Consoles 18 and 
1 9 are provided for communicating information from 
the primary processor 1 and secondary processor 4, 
respectively, wherein the I/O ERP posts status infor- 
mation to both consoles 18 and 19. 
10 Data integrity has been maintained at step 225 

upon successful completion of the failed synchron- 
ous remote copy I/O operation to the primary storage 
controller 3 and the secondary storage controller 6. 
Therefore, if a recovery is attempted at the second- 
15 ary site 1 5 the secondary storage controller 6 identi- 
fies the volume marked "failed synchronous remote 
copy" as not being useable until data on that volume 
are synchronized with other data in that synchroniza- 
tion group by data recovery means (conventional 
20 data base logs and/or journals for determining the 
state of that data on the volume). 

Step 227 tests to determine whether the I/O ERP 
2 received successful completion of the I/O opera- 
tions at the primary storage controller 3 and the sec- 
25 ondary storage controller 6 on the failed synchronous 
remote copy status update. Upon successful comple- 
tion, the I/O ERP 2 returns control to the Primary 
processor 1 at step 229. Otherwise step 231 per- 
forms a next level recovery notification which in- 
30 volves notifying an operator, via the console 1 8, of the 
failed volume and that a status of that volume at either 
the primary storage controller 3 or the secondary 
storage controller 6 may not be correct The notifica- 
tion is shadowed to the secondary site 1 5, via the con- 
35 sole 19 or a shared DASD data set, for indicating the 
specific volume status there. 

An error log recording data set is updated at step 
233. This update is written to either the primary DASD 
4 or some other storage location and is shadowed to 
40 the secondary site 1 5. Having completed the error re- 
covery actions, the I/O ERP 2, at step 235, posts to 
the primary application write I/O operation a "perma- 
nent error" for causing the primary application an er- 
ror normal "permanent error" recovery for the failed 
45 write I/O operation. Once the error is corrected, the 
volume states can be recovered, first to pending (re- 
copy changed data) and then back to full duplex. The 
data may later be re-applied to the secondary DASD 
7 once duplex pair is re-established. 
50 When establishing a duplex pair a volume can be 

w . identified, as. CRITICAL accordii3g..to a customer's 
needs. For a CRITICAL volume, when an operation 
results in failing a duplex pair, a permanent error fail- 
ure of the primary volume is reported irrespective of 
55 the actual error's location. With CRIT=Y, all subse- 
quent attempts to write to the primary DASD 405 of 
the failed pair will receive a permanent error, ensuring 
that no data is written to that primary volume that can- 

6 
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not also be shadowed to the paired secondary vol- 
ume. This permits complete synchronization with the 
primary application actions and the I/O data opera- 
tions when required. 

Consequently, the disaster recovery system 10 
described herein, introduces outboard synchronous 
remote copy such that a primary host process error 
recovery procedure having an I/O order (channel 
command word (CCW)) may change a status of a pri- 
mary and secondary synchronous remote copy vol- 
ume from duplex pair to failed duplex thereby main- 
taining data integrity for several types of primary and 
secondary subsystem errors. Storage based back- 
up, rather than application based back-up, wherein 
data updates are duplicated in real time has been pro- 
vided. The disaster recovery system 10 also attempts 
several levels of primary/secondary status updates, 
including: (1) primary and secondary storage control- 
ler volume status updates; (2) primary and secondary 
host processor notification on specific volume up- 
date status via operator messages or error log record- 
ing common data sets; and (3) CRITICAL volume in- 
dication, future updates to the primary volume can be 
prevented if the volume pair goes failed duplex. 
Hence, real time, full error disaster recovery is ac- 
complished. 

Asynchronous remote data shadowing is used 
when it is necessary to further increase a distance be- 
tween primary and secondary sites for reducing the 
probability that a single disaster will corrupt both pri- 
mary and secondary sites, or when primary applica- 
tion performance impact needs to be minimized. 
While the distance between primary and secondary 
sites can now stretch across the earth or beyond, the 
synchronization of write updates across multiple 
DASD volumes behind multiple primary subsystems 
to multiple secondary subsystems is substantially 
more complicated. Record write updates can be ship- 
ped from a primary storage controller via a primary 
data mover to a secondary data mover for shadowing 
on a secondary storage subsystem, but the amount of 
control data passed therebetween must be mini- 
mized while still being able to re-construct an exact 
order of the record write updates on the secondary 
system across several storage controllers as occur- 
red on the primary system across multiple DASD vol- 
umes behind several storage controllers. 

FIG. 4 depicts an asynchronous disaster recov- 
ery system 400 including a primary site 421 and a re- 
mote or secondary site 431. The primary site 421 in- 
cludes a primary processor 401, for example, an IBM 
ES/9000 running DFSMS/MVS host software. The 
primary processor 401 further includes application 
programs 402 and 403, for example, IMS and DB2 ap- 
plications, and a primary data mover (PDM) 404. A 
common sysplex clock 407 is included in the primary 
processor 401 for providing a common reference to all 
applications (402, 403) running therein, wherein all 
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system clocks or time sources (not shown) synchron- 
ize to the sysplex dock 407 ensuring all time depend- 
ent processes are properly timed relative to one an- 
other. The primary storage controllers 40S, for exanv 

5 pie, synchronize to a resolution appropriate to ensure 
differentiation between record write update times, 
such that no two consecutive write I/O operations to 
a single primary storage controller 404 can exhibit the 
same time stamp value. The resolution, and not the 

10 accuracy, of the sysplex timer 407 is critical. The 
PDM 404, though shown connected to the sysplex 
timer 407, is not required to synchronize to the sys- 
plex timer 407 since write I/O operations are not gen- 
erated therein. A sysplex timer 407 is not required if 

15 the primary processor 401 has a single time refer- 
ence (for example, a single multi-processor ES/9000 
system). 

A plurality of primary storage controllers 405. for 
example, IBM 3990 Model 6 storage controllers, are 

20 connected to the primary processor 401 via a plurality 
of channels, for example, fiber optic channels. Con- 
nected to each primary storage controller 405 is at 
least one string of primary DASDs 406, for example, 
IBM 3390 DASDs. The primary storage controllers 

25 405 and the primary DASDs 406 form a primary stor- 
age subsystem. Each storage controller 405 and pri- 
mary DASD 406 need not be separate units, but may 
be combined into a single drawer. 

The secondary site 431, located for example, 

30 some thousands of kilometers remote from the pri- 
mary site 421, similar to the primary site 421. in- 
cludes a secondary processor 411 having a second- 
ary data mover (SDM) 414 operating therein. Alterna- 
tively, the primary and secondary sites can be the 

35 same location, and further, the primary and second- 
ary data movers can reside on a single host processor 
(secondary DASDs may be just over a f ire-wall). A 
plurality of secondary storage controllers 415 are 
connected to the secondary processor 41 1 via chan- 

40 nels, for example, fiber optic channels, as is known in 
the art. Connected to the storage controllers 415 are 
a plurality of secondary DASDs 416 and a control in- 
formation DASD(s) 417. The storage controllers 415 
and DASDs 416 and 417 comprise a secondary stor- 

45 age subsystem. 

The primary site 421 communicates with the sec- 
ondary site 431 via a communication link 408. More 
specifically, the primary processor 401 transfers data 
and control information to the secondary processor 

50 411 by a communications protocol, for example, a vir- 
tual... teieconsmunjcatlons access method (VTAM) 
communication link 408. The communication link 408 
can be realized by several suitable communication 
methods, including telephone (T1 , T3 lines), radio, ra- 

55 db/telephone, microwave, satellite, etc. 

The asynchronous data shadowing system 400 
encompasses collecting control data from the pri- 
mary storage controllers 405 so that an order of all 

7 
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data writes to the primary DASDs 406 is preserved 
and applied to the secondary DASDs 41 6 (preserving 
the data write order across all primary storage sub- 
systems). The data and control information transmit- 
ted to the secondary site 431 , must be sufficient such 5 
that the presence of the primary site 421 is no longer 
required to preserve data integrity. 

The applications 402, 403 generate data or re- 
cord updates, which record updates are collected by 
the primary storage controllers 405 and read by the io 
PDM 404. The primary storage controllers 405 each 
grouped its respective record updates for an asyn- 
chronous remote data shadowing session and pro- 
vides those record updates to the PDM 404 via non- 
specific primary DASD 406 READ requests. Trans- is 
ferring record updates from the primary storage con- 
trollers 405 to the PDM 404 is controlled and opti- 
mized by the PDM 404 for minimizing a number of 
START I/O operations and time delay between each 
read, yet maximizing an amount of data transferred 20 
between each primary storage controller 405 and the 
primary processor 401. The PDM 404 can vary a time 
interval between non-specific READs to control this 
primary storage controller-host optimization as well 
as a currency of the record updates for the secondary 25 
DASDs 416. 

Collecting record updates by the PDM 404, and 
transmitting those record updates to the SDM 414. 
while maintaining data integrity, requires the record 
updates to be transmitted for specific time intervals 30 
and in appropriate multiple time Intervals with enough 
control data to reconstruct the primary DASDs 406 
record WRITE sequence across all primary storage 
subsystems to the secondary DASDs 41 6. Re-con- 
structing the primary DASDs 406 record WRITE se- 35 
quences is accomplished by passing self describing 
records from the PDM 404 to the SDM 414. The SDM 
414 inspects the self describing records for determin- 
ing whether any records for a gh^en time interval have 
been lost or are incomplete. 40 

FIGs 5 and 6 show a journal record format creat- 
ed by the PDM 404 for each self describing record, in- 
cluding a pref be header 500 (FIG. 5). and a record set 
infonmation 600 (FIG. 6) as generated by the primary 
storage controller 405. Each self describing record is 45 
further journaled by the SDM 414 for each time inter- 
val so that each self describing record can be applied 
in time sequence for each time interval to the second- 
ary DASDs 416. 

Referring now to FIG. 5, the prefix header 500. so 
which is inserted at the front of each record set^Jn^ 
dudes a total data length 501 for describing the total 
length of the pref be header 500 and actual primary re- 
cord set information 600 that is transmitted to the 
SDM 414 for each record set An operational time 55 
stamp 502 is a time stamp indicating a start time for 
the operational set that the PDM 404 is currently proc- 
essing. The operational time stamp 502 is generated 



by the PDM 404 (according to the sysplex timer 407) 
when performing a READ RECORD SET function to 
a set of the primary storage controllers 405. An I/O 
time 610 (FIG. 6) of the primary DASDs 406 write is 
unique for each primary storage controller 405 READ 
RECORD SET. The operational time stamp 502 is 
common across all storage controllers. 

A READ RECORD SET command is issued by 
the PDM 404 and can be predicated upon one of the 
following conditions: 

(1) Primary storage controller 405 attention inter- 
rupt based upon that primary storage controller 
predetermined threshold; 

(2) Primary processor 401 timer interrupt based 
upon a predetermined time interval; or 

(3) Record set infonmation indicates additional in- 
formation on outstanding record sets available 
but not yet read. 

Condition (2) uses a timer interval to control how 
far behind the secondary system 431 executes during 
periods of low activity. Condition (3) occurs when the 
PDM 404 fails to drain all record sets during a proc- 
essing interval which drives further activity for ensur- 
ing that the PDM 404 keeps up with primary storage 
controller 405 activity. 

A time interval group number 503 is supplied by 
the PDM 404 to identify a time interval (bounded by 
operational time stamp 502 and a records read time 
507) for which the current record sets belong (sets of 
records across all primary storage controllers 405 for 
a gh^en time interval group form consistency groups). 
A sequence number within group 504 is derived 
based upon a hardware provided identification (to the 
PDM 404) of a write sequence order of application 
WRITE l/Os for primary storage controller 405 for 
each record set within a given time interval group 
503. A primary SSID (substorage identification) 505 
uniquely identifies the specific primary storage con- 
troller of the primary storage controllers 405 for each 
record set. A secondary target volume 506 is as- 
signed by either the PDM 404 or the SDM 414 de- 
pending upon performance considerations. A records 
read time 507 supplies an operational time stamp that 
is common to all primary storage controllers 405 in- 
dicating an end time for the PDM 404 read record set 
process current interval. 

The operational time stamp 502 and the records 
read time 507 are used by the PDM 404 to group sets 
of road record sets from each of the primary storage 
controllers 405. Time synchronization for grouping 
sets of read record sets is key only: tcthe PDM 404 
and as such, the PDM 404 could be synchronized to 
a central processing unit (CPU) dock running only the 
PDM 404 not attached to the syspelx tinier 407. The 
PDM 404 does not write record updates, but the re- 
cord updates, as stated previously, must be syn- 
chronized to a common time source. 

Referring now to FIG. 6, the record set informa- 
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tion 600 is generated by the primary storage control- 
lers 405 and collected by the PDM 404. Update Spe- 
cific Information 601-610, Includes a primary device 
unit address 601 of each record indicating the actual 
primary DASD 406 that the record update occurred 
on. A cylinder number/head number (CCHH) 602 in- 
dicates a location on primary DASD 406 for each re- 
cord update. Primary SSID 603, the primary storage 
controller session identifier is the same as primary 
SSID 505. Status flags 604 provide status informa- 
tion regarding whether specific data records 620 fol- 
low. Sequence numbers 605 and 630 assign a num- 
ber to each record for indicating whether the entire re- 
cord set has been read (all data transferred to the 
PDM 404). Primary DASD write I/O type 606 is an op- 
eration indicator identifying the type of write opera- 
tion performed on each record, the operation indica- 
tors Including: update write; format write; partial track 
records follow; full track data follows; erase command 
performed; or write any performed. Search argument 

607 indicates initial positioning information for the 
first read record set data record 620. A sector number 

608 identifies that sector that the record was updated 
at Count field 609 describes a number of specific re- 
cord data fields 620 that follow. A host application 
time when the primary DASD 406 write update occur- 
red is recorded in time of updates 610. Specific re- 
cord data 620 provides a count/key/data (CKD) field 
of each record update. Lastly, the sequence number 
630 is compared to the sequence number 605 for in- 
dicating whether the entire read record set was trans- 
ferred to the PDM 404. 

The update records are handled in software 
groups called consistency groups so that the SDM 
414 can copy the record updates in the same order 
they were written at the primary DASDs 406. The in- 
formation used for creating the consistency groups 
(across all record sets collected from all storage con- 
trollers 405) includes the: operational time stamp 
502; time interval group number 503; sequence nunv 
ber within group 504; primary controller SSID 505; re- 
cords read time 507; primary device address 601 ; the 
primary SSID 603; and the status flags 604. The in- 
formation used for determining whether all records for 
a time interval group have been received for each 
storage controller 405 at the SDM 414 includes the: 
time interval group number 503; sequence number 
within group 504; physical controller ID 505; the pri- 
mary SSID 603; and a total number of read record 
sets returned from each primary storage controller 
405 for each operational timeJnter^al. Tiia infonnan 
tion necessary to place record updates on the sec- 
ondary DASDs 416- equivalent y to the primary 
DASDs 406 record updates with full recover possible 
includes the: secondary target volume 506; CCHH 
602; primary DASD write I/O type 606; search argu- 
ment 607; sector number 608; count 609; time of up- 
dates 610; and the specific record data 620. 



FIGs 7 and 8 show a state table 700 and a master 
journal 800, respectively, for describing a current 
journal contents, which simplifies recovery time and 
journal transfer time. The state table 700 provides 

5 configuration information, collected by and common 
to the PDM 404 and SDM 414, and includes primary 
storage controller session identifiers (SSID numbers) 
and the volumes therein, and the corresponding sec* 
ondary storage controller session identifiers and the 

10 corresponding volumes. Thus the configuration infor- 
mation tracks which primary volumes 710 or primary 
DASD extents map to secondary volumes 711 or sec- 
ondary DASD extents. With a simple extension to the 
state table 700 indicating partial volume extents 712 

15 (CCHH to CCHH), partial volume remote copy can be 
accomplished using the same asynchronous remote 
copy methods described herein, but for a finer gran- 
ularity (track or extent) than full volume. 

The master journal 800 includes: consistency 

20 group number; location on journal volumes; and op- 
erational time stamp. The master journal 800 further 
maintains specific record updates as grouped in con- 
sistency groups. The state table 700 and master jour- 
nal 800 support disaster recovery, and hence must be 

25 able to operate in a stand-alone environment wherein 
the primary system 401 no longer exists. 

A time stamp control is placed at the front and 
back of each master journal 800 to ensure that the en- 
tire control entry was successfully written. The time 

30 stamp control is further written to the secondary 
DASDs 417. The control elements include dual en- 
tries (1) and (2), wherein one entry is always a current 
entry, for example: 

(1) Timestamp control I Control Info I Time- 
35 stamp Control 

(2) Timestamp Control I Control Info I Time- 
stamp Control. 

At any point in time either entry (1) or (2) is the 
current or valid entry, wherein a valid entry is that en- 

40 try with equal timestamp controls at the front and 
back. Disaster recovery uses the valid entry with the 
latest timestamp to obtain control information. This 
control information, along with state Information (en- 
vironmental information regarding storage control- 

45 lers, devices, and applied consistency groups), is 
used for determining what record updates have been 
applied to the secondary storage controllers 415. 

After all read record sets across all primary stor- 
age controllers 405 for a predetermined time interval 

50 are received at the secondary site 431 , the SDM 41 4 
interprets the received control Infonnatjon and ap^^ 
plies the received read record sets to the secondary 
DASDs 416 in groups of record updates such that the 
record updates are applied in the same sequence that 

55 those record updates were originally written on the 
primary DASDs 406. Thus, all primary application or- 
der (data integrity) consistency is maintained at the 
secondary site 431 . This process is hereinafter refer- 
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red to as forming consistency groups. Forming con- 
sistency groups is based on the following assump- 
tions: (A) application writes that are independent can 
be performed in any order if they do not violate con- 
troller sequence order; (B) application writes that are 5 
dependent must be performed in timestamp order, 
hence an application cannot perform a dependent 
write number two before receiving control unit end, 
device end from write number one; and (C) a second 
write will always be either (1) in a same record set io 
consistency group as a first write with a later time- 
stamp or (2) in a subsequent record set consistency 
group. 

Referring to FIG. 9, an example ctf forming a con- 
sistency group (the consistency group could be is 
formed at either the primary site 421 or secondary 
site 431 ), for example, for storage controllers SSID 1 , 
SSID 2, and SSID 3 is shown (any number of storage 
controllers can be included but three are used in this 
example for darity). Time intervals T1 . T2 and T3 are 20 
assumed to occur in ascending order. An operational 
time stamp 502 of time interval T1 is established for 
storage controllers SSID 1. SSID 2 and SSID 3. The 
PDM 404 obtains record set data from storage con- 
troller SSIDs 1 , 2. and 3 for time interval T1-T3. The 25 
record sets for SSIDs 1, 2. and 3 for time interval T1 
are assigned to time interval group 1, G1 (time inter- 
val group number 503). The sequence number within 
group 504 is shown for each SSID 1 , 2, and 3. wherein 
SSID has three updates as 11:59. 12:00, and 12:01, 30 
SSID 2 has two updates at 12:00 and 12:02, and SSID 
3 has three updates at 11:58, 11:59, and 12:02. Re- 
cord sets of time intervals T2 and T3 are listed but ex- 
ample times of updates are not given for simplicity. 

Consistency group N can now be formed based 35 
upon the control information and record updates re- 
ceived at the secondary site 431. In order to ensure 
that no record update in time interval group number 
one is later ttian any record update of time interval 
group number two, a min-time is established which is 40 
equal to a the earliest read record set time of the last 
record updates for each storage controller SSID 1, 2, 
and 3. In this example then, min-time is equal to 
12:01. Any record updates having a read record set 
time greater than or equal to min-time is included in 45 
the consistency gnDup N + 1. If two record update 
times to a same volume were equal, though unlikely 
given sufficient resolution of the sysplex timer 407, 
the record update having the earlier sequence num- 
ber within the time interval group N is kept with that so 
. group fox: consistency group N. The record updates 
are now ordered based upon read record set times. 
Record updates having equal times will cause the re- 
cord update having the lower sequence number to be 
place before the later sequence numbered record up- 55 
date. Alternatively, record updates having equal time 
stamps, but to differing volumes, may be ordered ar- 
bitrarily as long as they are kept in the same consis- 



tency group. 

If a primary storage controller 405 fails to corrv 
plete a response to a read record set during a speci- 
fied time interval, then a consistency group cannot be 
formed until that primary storage controller 405 com- 
pletes. In the event that the primary storage controller 
405 fails to complete Its operation, then a missing in- 
terrupt results causing a system missing interrupt 
handler to receive control and the operation will be 
terminated. On the other hand, if the primary storage 
controller 405 timely completes the operation then 
the I/O will be driven to completion and normal oper- 
ation will continue. Consistency group formation ex- 
pects that write operations against the primary stor- 
age controllers 405 will have time stamps. Some pro- 
grams, however, will cause writes to be generated 
without time stamps, in which case the primary stor- 
age controller 405 will return zeros for the time 
stamp. Consistency groupformation can bound those 
records without tinte stamps based upon the time- 
stamp that the data was read. If too many record up- 
dates without time stamps occur over a time interval 
such that the record updates are not easily bounded 
by consistency group times, then an enror that the du- 
plex volumes are out of synchronization may result. 

FIGs 10 and 11 are flow diagrams presenting the 
method of forming consistency groups. Referring to 
FIG. 10, the process starts at step 1000 with the pri- 
mary site 421 establishing remote data shadowing to 
occur. At step 1010 all application I/O operations are 
time stamped using the sysplex timer 407 as a syn- 
chronization dock (FIG. 4). The PDM 404 starts a re- 
mote data shadowing session with each primary stor- 
age controller 405 at step 1020 which includes iden- 
tifying those primary volumes that will have data or 
records shadowed. Record set information 600 is 
trapped by the primary storage controllers 405 for 
each application WRITE I/O operation (seie FIG. 6) by 
step 1030. 

Step 1 040 involves the PDM 404 reading the cap- 
tured record set information 600 from each primary 
storage controller 405 according to a prompt including 
an attention message, a predetermined timing inter- 
val, or a notification of more records to read as descri- 
bed earlier. When the PDM 404 begins reading record 
sets, at step 1050, the PDM 404 prefixes each record 
set with a prefix header 500 (see FIG. 5) for creating 
specif ic journal records (a journal record Includes the 
prefix header 500 and the record set informatton 
600). The journal records contain the control Informa- 
. tion.(and records) necessary for forming consistency 
groups at the secondary site 431 (or at the primary 
site 421). 

At step 1060 the PDM 404 transmits the gener- 
ated journal records to the SDM 414 via the commu- 
nications link 408 (or within the same data mover sys- 
tem if the consistency groups are formed therein). 
The SDM 414 uses the state table 700 at step 1070 
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to gather the received record updates by group and 
sequence numbers for each time interval group and 
primary storage controller 405 established for the 
data shadowing session. The SDM 414 inspects the 
journal records at step 1080 to determine whether all 
record information has been received for each time 
interval group. If the journal records are incomplete, 
then step 1085 causes the SDM 414 to notify the 
PDM 404 to resend the required record sets. If the 
PDM 404 is unable to correctly resend, then the du- 
plex volume pair is failed. If the journal records are 
complete, then step 1090 is performed which enconv 
passes the SDM 414 forming the consistency groups. 

Referring to FIG. 11, steps 1100-1160 represent- 
ing step 1090 (FIG. 10) for forming consistency 
groups is shown. Consistency group formation starts 
at step 1100 wherein each software consistency 
group is written to an SDM 414 journal log ("hard- 
ened") on the secondary DASD 417 (FIG. 4). Step 
1110 performs atest for determining whether the time 
interval groups are complete, that is, each primary 
storage controller 405 must have either presented at 
least one read record set buffer or have confirmation 
from the PDM 404 that no such record updates were 
placed in the record set buffer, and all read record set 
buffers with data (or null) must have been received by 
the SDM 414. If a time interval group is incomplete, 
then step 1110 retries reading the record sets from 
the primary storage controller 405 until the required 
data is received. If errors occur, a specific duplex vol- 
ume pair or pairs may be failed. Having received conrv 
plete time interval groups, step 1120 determines a 
first consistency group journal record. The first (or 
current) consistency group journal record is that re- 
cord which contains the earliest operational time 
stamp 502 and the earliest time of update 610 of all 
records having equal operational time stamps 502. 

Step 1130 inspects the records contained in the 
current consistency group journal record to determine 
which record will be the last record to be included 
therein (some records will be dropped and included in 
the next consistency group journal record). The last 
record in the current consistency group journal record 
is determined as a minimum update time (min-time) 
of the maximum update times for each primary stor- 
age controller 405 (that is, the last update of each pri- 
mary storage controller 405 is compared and only the 
earliest of these remains In the current consistency 
group journal record). 

Those remaining record updates in the current 
consistency group journal record are ordered accord- 
ing to time of update 610 and sequence number within 
group 504 by step 1140. A primary storage controller 
405 that had no record updates does not participate 
in the consistency group. At step 1150, the remaining 
record updates of the current consistency group (hav- 
ing update times later than min-time) are passed to 
the next consistency group. Each sequence number 



within a group 504 should end with a null buffer indi- 
cating that all read record sets have been read for that 
operational time interval. If the null buffer is absent, 
then the step 1120 of defining the last record in the 
5 current software consistency group, coupled with the 
records read time 507 and time of update 610 can be 
used to determine the proper order of the application 
WRITE I/O operations across the primary storage 
controllers 405. 
10 Step 1160 represents a back-end of the remote 

data shadowing process wherein specific write up- 
dates are applied to secondary DASDs 41 6 under full 
disaster recovery constraint. If when writing the up- 
dates to the secondary DASDs 416 an I/O error oc- 
15 curs, or the entire secondary site 431 goes down and 
is re-initialized, then the entire consistency group that 
was in the process of being written can be re-applied 
from the start This permits the remote shadowing to 
occur without having to track which secondary 
20 DASDs 416 l/Os have occurred, which l/Os have not 
occurred, and which l/Os were in process, etc. 

A key component of step 1160 is that the PDM 
414 causes the records to be written efficiently to the 
secondary DASDs 41 6 so that the secondary site 431 
25 can keep pace with the primary site 421 . The requisite 
efficiency is accomplished, in part, by concurrently 
executing multiple I/O operations to different second- 
ary DASDs 416. Serially writing one secondary 
DASD 416 at a time would cause the secondary site 
30 431 to fall too far behind the primary site 421. Yet 
more efficiency is gained at the secondary site 431 
by writing the records for each consistency group des- 
tined for a single secondary device via a single chan- 
nel command word (CCW) chain. Within each single 
35 CCW chain, the I/O operations therein can be further 
optimized as long as those I/O operations to each 
secondary DASD 416 data track are maintained in 
the order of occurrence on the primary volumes. 
Optimizing secondary I/O operations for specific 
40 consistency groups and within single CCW chains is 
based in part upon the pattern of primary write I/O op- 
erations, and in part upon the physical characteristics 
of the secondary DASDs 416. Optimization may vary 
somewhat depending upon whether secondary 
45 DASD 415 is count/key/data (CKD). extended 
count/key/data (ECKD), fixed block architecture 
(FBA), etc. Consequently, a number of WRITE l/Os 
(m) to a primary DASD 406 volume during a given 
time interval can be reduced to a single START I/O 
50 operation to a secondary DASD 41 6 volume. This op- 
...^ . tiinfza£k>n otthe number of START l/Os to the second- 
ary storage controllers 415 of m:1 can allow the sec- 
ondary DASDs 41 6 to catch up with and thereby clos- 
er shadow the record updates at the primary site 421 . 
55 A key to successful remote data shadowing, and 

hence secondary I/O optimization, is minimizing un- 
recoverable errors in any of the concurrent multiple 
I/O operations to secondary DASDs 41 6 so that con- 
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sistent cxjpies are available for recovery. A failure in 
a given secondary write coidd permit a later depend- 
ent write to be reconJed without the conditioning write 
(e.g., a log entry indicating that a data base record 
has been updated when in reality the actual update 
write for the data base had failed violates the se- 
quence integrity of the secondary DASD 416 copy). 

A failed secondary 41 6 copy is unusable for ap- 
plication recovery until that failure to update has been 
recovered. The failed update could be corrected by 
having the SDM 414 request a current copy from the 
PDM 404. In the mean time the secondary data copy 
is inconsistent and hence unusable until the PDM 404 
responds vtnth the current update and all other previ- 
ous updates are processed by the PDM 41 4. The time 
required to recover the failed update typically pres- 
ents an unacceptably long window of non-recovery 
for adequate disaster recovery protection. 

Effective secondary site 431 I/O optimization is 
realized by inspecting the data record sets to be writ- 
ten for a given consistency group and building chains 
based upon rules of the particular secondary DASD 
416 architecture, for example, an ECKD architecture. 
The optimization technique disclosed herein simpli- 
fies recovery from I/O errors such that when applying 
a consistency group, if an I/O error occurs, the CCW 
chain can be re-executed, or in the event of a second- 
ary initial program load (IPL) recovery, the entire con- 
sistency group can be re-applied without data loss. 

FIG. 12 summarizes full consistency group re- 
covery (FGGR) rules for building CCW chains for all 
WRITE I/O combinations for an ECKD architecture, 
wherein OCHHR record fonmat is used (cylinder nurrv 
ber, head number, record number). FIG. 12 Is created 
by inspecting each possible combination of WRITE 
I/O operations to a DASD track within a consistency 
group's scope. The FCGR rules of FIG. 12, described 
in FIG.s 13A and 13B, are then followed to govern 
data placement (secondary DASD 416 I/O write CCW 
chains) for yielding full recovery for an error in apply- 
ing a consistency group. The FCGR rules depicted in 
FIG. 12 would be extended appropriately as new 
WRITE I/O operations are added. These rules can ex- 
ist in hardware or software at the secondary site 431 . 
The FCGR rules advantageously reduces READ re- 
cord set to a same DASD track analysis to an inspec- 
tion of the primary DASD 406 WRITE I/O type, search 
argument, and count and key fields. 

If a DASD track is written v^thout inspecting the 
consistency group write operations as shown in FIG. 
12, then previously written data records potentially 
cannot be re-written. For example, assume that a 
chain includes: 

WRITE UPDATE to record five; and 
FORMAT WRITE to record one, 
wherein record one and record f ive occur on the same 
DASD track with record one preceding record five. 
Record f h/e is updated by an UPDATE WRITE CCW 



and a FORMAT WRITE I/O CCW updates recond one 
erasing a remainder of the track thus deleting record 
five. If this chain had to be re-executed, a LOCATE 
RECORD CCW that will position to the beginning of 
5 record f ive will no longer have a positioning point (re- 
cord five no longer exists), and the chain is not fully 
recoverable from the beginning. Since the write oper- 
ations have already been successful at the primary 
site 421. always being able to apply an entire consis- 
10 tency group on the secondary DASD 41 6 is required 
to maintain data consistency and integrity. 

FIG. 14, steps 1410 through 1470, provides more 
detail as to the process represented by step 1160 of 
FIG. 11, while using the FCGR rules defined in FIG. 
IS 12. At step 1410 the SDM 414 divides the records of 
the current consistency group into two categories. A 
first category includes I/O orders directed to a same 
secondary DASD volume, and a second category in- 
cludes I/O orders of those records in the first category 
20 that are directed to a same CCHH (i.e., records being 
updated to a same DASD track). 

Having categorized the records of the current 
consistency group, step 1420 conforms application 
WRITE l/Os and SDM 414 WRITE l/Os to the archi- 
25 tecture of the secondary DASDs 41 6, for example, to 
ECKD architecture FCGR rules (see FIG. 12) for iden- 
tifying data placement on a track and track/record ad- 
dressing. The SDM 414 groups secondary DASD 
WRITE I/O operations to the same volumes into sin- 
30 gle I/O CCW chains at step 1 430. Step 1 440 involves 
moving the head disk assembly (HDA) of each sec- 
ondary DASD 416 according to search arguments 
and specific record data (CKD fields) for the actual 
secondary DASD 416 writes. 
35 step 1450 compares READ SET BUFFERS one 

and two for those records making up the second cat- 
egories (there typically will be a plurality of second 
categories, one for each track receiving records), us- 
ing the FCGR rules of FIG. 1 2 for determining wheth- 
40 er a subsequent write operation invalidates a previ- 
ous write operation or DASD search argument (posh 
tioning at a record that is now erased, etc.). The 
READ SET BUFFERS one and two contain adjacent 
read record sets. Following the FCGR rules ensures 
45 that the SDM 414 can re-write an entire consistency 
group, in the event of an error, without re-receiving re- 
cord updates from the primary site 421. After the 
SDM 414 applies the current consistency group to the 
secondary DASD 416, step 1460 updates the state ta- 
50 ble (FIG. 7) and the master journal (FIG. 8). 

The remote copy process- continues in real time 
as step 1470 gets a next consistency group (which 
becomes the current consistency group) and returns 
processing to step 1410. The remote copy process 
55 will Stop if the primary site 421 to secondary site 431 
communication terminates. The communication may 
terminate if volume pairs are deleted from the proc^ 
ess by the PDM 404, the primary site is destroyed 
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(disaster occurs), an orderly shutdown is performed, 
or a specific takeover action occurs at the secondary 
site 431. Consistency groups journaled on the sec- 
ondary site 431 can be applied to the secondary 
DASD 41 6 during a talceover operation. The only data 
lost is that data captured by the primary site 421 that 
has not been completely receh^ed by the SDM 414. 

In summary, synchronous and asynchronous re- 
mote data duplexing systems have been described. 
The asynchronous remote data duplexing system 
provides storage based, real time data shadowing. A 
primary site runs applications generating record up- 
dates, and a secondary site, remote from the primary 
site, shadows the record updates and provides disas- 
ter recovery for the primary site. The asynchronous 
remote data duplexing system comprises a sysplex 
timer for synchronizing time dependent processes in 
the primary site, and a primary processor at the pri- 
mary site for running the applications, the primary 
processor having a primary data mover therein. A 
plurality of primary storage controllers are coupled to 
the primary processorfor issuing write I/O operations 
for each record update, each primary storage control- 
ler DASD write I/O operation being synchronized to 
the sysplex timer. A plurality of primary storage devic- 
es receive the write I/O operations and store the re- 
cord updates therein accordingly. The primary data 
mover collects record set information from the plural- 
ity of primary storage controllers for each record up- 
date and appends a prefix header to a predetermined 
group of record set informations. The prefix header 
and predetermined group of record set informations 
form the self describing record sets. Each record set 
information includes a primary device address, a cy- 
linder number and head number (CCHH), a record up- 
date sequence number, a write I/O type, ai search ar- 
gument, a sector number, and a record update time. 
The prefix header includes a total data length, an op- 
erational time stamp, a time interval group number, 
and a records read time. A secondary processor at 
the secondary site has a secondary data mover, the 
secondary data mover receiving the self describing 
record sets from the primary site. A plurality of sec- 
ondary storage controllers are coupled to the second- 
ary processor, and a plurality of secondary storage 
devices are coupled to the secondary storage con- 
trollers for storing the record updates copies. The 
secondary data mover determines whether the trans- 
mitted self describing record sets are complete and 
forms consistency groups from the self describing re- 
cord sets and provides the record updates from each 
consistency group to the plurality of secondary stor- 
age controllers for writing to the plurality of secondary 
storage devices in an order consistent with a se- 
quence that the record updates were written to the 
plurality of primary storage devices, 

While the invention has been particularly shown 
and described with reference to preferred emt>odi- 
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ments thereof, it will be understood by those skilled 
in the art that varbus changes in form and details may 
be made therein without departing from the scope of 
the invention as defined in the appended claims. For 

5 example, the consistency groups have been descri- 
bed as being formed by the secondary data mover 
based upon receh^ed self describing record sets, 
however, the consistency groups could be formed at 
the primary site based upon write record sets or else- 

10 where in the secondary site. The formats the storage 
devices at the primary and secondary sites need not 
be identical. For example, CKD records could be con- 
verted to f ixed block architecture (FBA) type records, 
etc. Nor are the storage devices meant to be limited 

15 to DASD devices. 



Claims 

20 1 . A method of providing asynchronous data duplex- 
ing, wherein data updates generated by one or 
more applications running in a primary processor 
are receh^ed by a primary storage subsystem, the 
primary storage subsystem causing I/O write op- 

25 erations to write each data update therein, each 

write I/O operation being time stamped, the time 
stamps synchronized by a common timer, and 
wherein a secondary system, whether local to or 
remote from the primary processor, shadows the 

30 data updates in sequence consistent order such 

that the secondary site is available for disaster re- 
covery purposes, the method comprising the 
steps of: 

(a) time stamping each write I/O operation oc^ 
35 curring in the primary storage subsystem; 

(b) capturing write I/O operation record set in- 
formation from the primary storage subsys- 
tem for each data update; 

(c) generating self describing record sets 
40 from the data updates and respective record 

set informations, the self describing record 
sets containing sufficient control information 
to enable recreation of a sequence of the write 
I/O operations solely by the secondary sys- 
45 tem; 

(d) grouping the self describing record sets 
into interval groups, each interval group being 
measured from an operational time stamp 
start time and continuing for a predetermined 

50 interval threshold; and 

(e) selecting a current conslstancy group as 
that interval gmup of self describing record 
sets having an earliest operational time 
stamp, the individual data updates being or- 

55 dered within the current consistency group 

based upon time sequences of the I/O write 
operations in the primary storage subsystem. 

13 
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2. The method as claimed in daim 1 wherein the 
step (b) further includes Initiating sessions with 
the primary storage subsystem based upon the 
operational time stamps for identifying a starting 
time for each interval group, each interval group s 
being bounded by consecutive operational time 
stamps. 

3. The method as claimed in daim 1 or daim 2 
wherein the step (d) indudes adding a prefbc io 
header describing each interval group. 

4. The method as daimed in any preceding daim 
further comprising a step (f) transmitting the In- 
terval groups of self describing record sets to the is 
secondary site . 

5. The method as daimed in daim 4 further com- 
prising a step (g) determining at the secondary 

site whether each recen/ed self describing record 20 
set is complete. 

6. The method as daimed In daim 5 wherein the 
step (g) further indudes the secondary site re- 
questing the primary site to re-transmit any miss- 25 
ing data updates if the secondary site determined 

a self describing record set is incomplete. 

7. The method as daimed in daim 6 further conv 
prising a step (h) determining at the secondary 30 
site whether each time interval group is com- 
plete. 

8. The method as claimed In daim 7 wherein the 
step (h) further indudes the secondary site re- 35 
questing the primary site to re-send a missing re- 
corcl set if the secondary site determined that an 
interval group was incomplete. 

9. The method as daimed in daim 8 further com- 40 
prising a step (i) writing the received data updates 

at the secondary site to the secondary storage 
subsystem according to the sequence of the cor- 
responding write I/O operations at the primary 
site as ordered in the consistency groups. 45 

10. A method for providing remote data shadowing 
for disaster recovery purposes in a data process- 
ing system induding a primary site having a pri- 
mary processor running a primary data mover so 
and applications generating record updates, the 
primary processor coupled to a primary storage 
subsystem having storage devices for storing the 
record updates according to write I/O operations 
issued by the primary processor to the primary 55 
storage subsystem, the primary site further in- 
duding a common system timerfor synchronizing 
time dependent operations in the primary site, 

14 



the system further induding a secondary site 
having a secondary processor communicating 
with the primary processor, and a secondary 
storage subsystem for storing copies of the re- 
cord updates in sequence consistent order, the 
method comprising the steps of: 

(a) time stamping each write I/O operation in 
the primary storage subsystem; 

(b) establishing a session with each storage 
device in the primary storage subsystem; 

(c) capturing record set information from each 
storage device in the primary storage subsys- 
tem; 

(d) reading record sets and respective record 
set information in the primary data mover, 

(e) pref being each record set with a header 
and creating self describing record sets there- 
from; 

(f) transmitting the self describing record sets 
to the secondary processor in time interval 
groups according to predetermined time inter- 
vals; 

(g) forming consistency groups from the self 
describing record sets; and 

(h) shadowing the record updates of each 
consistency group to the secondary storage 
subsystem in a sequence consistent order 

11. The method as claimed in daim 10 wherein the 
record sets are transmitted to the secondary 
processor asynchronously. 

12. The method as daimed in daim 10 or daim 11 
wherein the step (g) is performed at the second- 
ary site. 

13. The method as daimed in any of dainr^ 10 to 12 
wherein the step (f) further indudes determining 
at the secondary site whether each received self 
describing record set is complete. 

14- The method as claimed in daim 13 wherein the 
step (f) further indudes requesting the primary 
site to re-transmit any missing record updates if 
the primary site determined a received self de- 
scribing record set is incomplete. 

15. The method as daimed in any of daims 10 to 14 
further comprising a step (i) determining at the 
secondary site whether each time Interval group 
is complete. 

16. The method as claimed in daim 15 wherein the 
step (i) further indudes requesting the primary 
site to re-send a missing record set if the second- 
ary site determined that a interval group was in- 
complete. 
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17. The method as claimed in any of claims 10 to 16 
wherein the step (c) identifies, in the record set 
information, a physical location on the primary 
storage devices where each record update is 
stored. s 

18. The method as claimed in claim 17 wherein the 
step (c) identifies, in the record set information, 
a sequence and timeof update of each record up- 
date stored to the primary storage devices within io 
the session. 

19. The method as claimed in any of claims 10 to 18 
wherein the step (e) identifies, in the prefix head- 
er, an interval group number for the session and is 
sequence within group for each record update re- 
ferred to therein. 

20. A primary data processing system having a pri- 
mary processor running one or more applica- 20 
tions, the one or more applications generating re- 
cord updates, the primary processor generating 
self describing record sets therefrom, the self de- 
scribing record sets being sent to a secondary 
system, the secondary system shadowing the re- 25 
cord updates in sequence consistent order based 
upon the self describing record sets for real time 
disaster recovery purposes, the primary proces- 
sor being coupled to a primary storage subsys- 
tem wherein the primary storage subsystem re- 30 
ceives the record updates and executes write I/O 
operations for storing each record update therein, 
the primary processor comprising: 

a timer for providing a common time 
source to the applications and primary storage 35 
subsystem for synchronization purposes; and 

primary data mover means prompting the 
primary storage subsystem for providing record 
set information to the primary data mover means 
for each record update, the primary data mover 40 



means grouping a plurality of record updates and 
each corresponding record set information into 
time interval groups, and inserting a prefix head- 
er thereto, each time interval group the self de- 
scribing record sets, interval groups, and insert- 
ing a prefix header thereto, each time interval 
group the self describing record sets. 



22. The primary system as claimed in claim 20 or 
claim 21 wherein the primary data mover means 
collects record set information for each write I/O 
operation for each primary storage controller of 
the plurality of primary storage controllers par- 
ticipating with each time interval group. 

23. The primary system as claimed in any of claims 
20 to 22 wherein each write I/O operation is time- 
stamped in the primary processor relative to the 
sysplex timer, each write I/O operation being is- 
sued to a primary storage controller of the plur- 
ality of primary storage controllers, each primary 
storage controller preserving the time-stamp and 
returning that time-stamp in the corresponding 
read record set to the primary data mover means. 

24. The primary system as claimed in claim 23 
wherein each record set information identifies a 
corresponding record update's physical location 
on a primary storage device of the plurality of pri- 
mary storage devices. 

25. The primary system as claimed in claim 23 or 
claim 24 wherein each record set Information 
identifies a corresponding record update's pri- 
mary subsystem identification, primary device 
address, cylinder number, and head number. 

26. The primary system as claimed in claim 23 
wherein the primary data mover means identifies 
a relative sequence of each write I/O update 
across all primary storage controllers participat- 
ing in a time interval group. 

27. The primary system as claimed in claim 26 
wherein the primary data mover means creates a 
state table for journaling record updates and 
cross referencing a storage location of each re- 
cord update on the primary system and the sec- 
ondary system. 

28. The primary system as claimed in datm 26 
wherein the primary data mover means commu- 

45 nicates the state table to the secondary system. 

29. A remote data shadowing system including a pri- 
mary site and a secondary site, the secondary 
site asynchronously shadowing record updates of 
the primary site In real time for disaster recovery 
purposes, the record updates generated by appli- 
cations running at the primary site, the primary 
site comprising: 

a sysplex timer, 

a primary processor running the applica- 
tions generating the record updates and issuing 
a corresponding write I/O operation for each re- 
cord update, the primary processor having a pri- 

15 



21. The primary system as claimed in claim 20 

wherein the primary storage subsystem compris- so 
es: 

a plurality of primary storage controllers, 
the plurality of primary storage controllers issu- 
ing the write I/O operations; and 

a plurality of primary storage devices cou- 55 
pled to the plurality of primary storage control- 
lers. 
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mary data mover therein; 

a plurality of primary storage controllers 
directed to store the record updates, the plurality 
of primary storage controllers executing the is- 
sued write I/O operation for each record update; 5 
and 

a plurality of primary storage devices re- 
ceiving and storing the record updates therein ac- 
cording to the corresponding write I/O operations, 

wherein the primary processor and each io 
write I/O are time-stamped by the primary proc- 
essor, as synchronized by the sysplex timer, such 
that write I/O operations are accurately sequence 
ordered relative to each other, the primary data 
mover collecting sets of record updates and com- is 
bining each record set information as provided by 
each one of the plurality of primary storage con- 
trollers with the corresponding record update, 
each record set information including a relative 
sequence and time of each corresponding write 20 
I/O operation, the primary data mover collecting 
record updates into time interval groups and in- 
serting a prefix header to each time interval 
group, wherein the prefix header includes infor- 
mation identifying the record updates included in 25 
each time interval group, each record set infor- 
mation and prefix header combined for creating 
self describing record sets, the self describing re- 
conj sets being transmitted to the secondary 
site, wherein the self describing record sets pro- 30 
vide information adequate for the secondary site 
to shadow the record updates therein in se- 
quence consistent order without further commu- 
nications from the primary site. 
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FIG. 13 



FIG. 13A 




B - IF #1'S SEARCH ARQ IS HIGHER THAN THE SEARCH ARG FOR #2, 
THEN THROW #1, ELSE C30 BOTH. 

C -IF #VS RECORD IS EQUAL TO OR HIGHER THAN THE FIRST RECORD 
I N #2, THEN THROW #1 , ELSE DO BOTH. 

D - IF #2 IS UPDATING RO. THEN DO BOTH, ELSE ERROR 

E - ERROR (SHOULD NEVER HAPPEN). 

E*- ERROR IF #1 AND #2 ARE THE SAME RECORD. (SHOULD 
NEVER HAPPEN WITHOUT A FORMAT WRITE IN BETWEEN). 

F - IF FIRST RECORD IN #2 IS R1 . THEN WRITE BOTH. ELSE ERROR. 

G -IF #1 S SEARCH ARQ IS EQUAL TO OR HIGHER THAN THE 
SEARCH ARG FOR #2, THEN THROW #1. ELSE ERROR. 

H -IF #1 'S SEARCH ARQ IS HIGHER THAN THE LAST RECORD 
FOR #2. THEN THROW #1. ELSE IF #2'S SEARCH ARG IS 
HIGHER THAN THE LAST RECORD IN #1. THEN ERROR. ELSE 
WRITE BOTH. 



TO OPTIMIZE FURTHER, CAN DO THE FOLLOWING- INSTEAD: 

IF (I S SEARCH IS EQUAL TO OR HIGHER THAN THE LAST RECORD 
IN #2) OR (THE LAST RECORD IN #1 iS EQUAL TO OR 
HIGHER THAN THE LAST RECORD IN #2) AND (2'S SEARCH 
IS LESS THAN OR EQUAL TO THE LAST RECORD IN #1) 
THEN THROW 1 

ELSE IF (#2'S SEARCH ARQ IS HIGHER THAN THE LAST RECORD 
IN #1) 

THEN ERROR 
ELSE WRITE BOTH 

I 
I 
I 
I 



I 
I 
I 
I 
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J - IF #2'S RECORD (OR SEARCH) IS HIGHER THAN THE LAST RECORD IN 
#1, THEN ERROR, ELSE WRITE BOTH. 

K -IF #2'S RECORD (OR SEARCH) IS HIGHER THAN #1'S SEARCH. THEN 
ERROR. ELSE WRITE BOTH. 

L -IF #1 'S SEARCH ARQ IS EQUAL TO OR HIGHER THAN #2'S SEARCH 
ARG THEN BTHER WRITE BOTH OR OK TO THROW #1 . ELSE ERROR. 

M -IF (#1 'S SEARCH ARQ IS EQUAL TO OR HIGHER THAN #2'S SEARCH 
ARG) THEN THROW 1 

ELSE IF (#2 S SEARCH ARQ IS HIGHER THAN THE LAST RECORD IN #1) 
THEN ERROR 
ELSE WRITE BOTH. 

N -IF #2'S SEARCH ARQ IS HIGHER THAN THE LAST RECORD IN #1 . 
THEN ERROa ELSE WRITE BOTH. 

R -OK TO THROW #1. 
T -MUST THROW 1. 
W -WRITE BOTH. 

WMF #1 AND #2 HAVE THE SAME RECORDS, THEN THROW #1. ELSE 
DO BOTH OR MERGE RECORDS AND DO ONE WRITE. 



FIG. 13B 
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